# STM32 Blue Pill / Cortex-M3 Instruction Set (Summary)

## 1 Data Processing Instructions

| Instruction        |         | Description                            |
|--------------------|---------|----------------------------------------|
| MOV Rd,            | #imm    | Move immediate value to register       |
| MOV Rd,            | Rm      | Move value from register to register   |
| MVN Rd,            | Rm      | Move NOT of register                   |
| ADD Rd,<br>Rm/#imm | Rn,     | Add                                    |
| SUB Rd,<br>Rm/#imm | Rn,     | Subtract                               |
| RSB Rd,            | Rn, Rm  | Reverse subtract                       |
| ADC Rd,            | Rn, Rm  | Add with carry                         |
| SBC Rd,            | Rn, Rm  | Subtract with carry                    |
| AND Rd,<br>Rm/#imm | Rn,     | Bitwise AND                            |
| ORR Rd,<br>Rm/#imm | Rn,     | Bitwise OR                             |
| EOR Rd,<br>Rm/#imm | Rn,     | Bitwise XOR                            |
| BIC Rd,            | Rn, Rm  | Bit clear                              |
| CMP Rn,            | Rm/#imm | Compare (sets flags)                   |
| CMN Rn,            | Rm      | Compare negative (adds and sets flags) |

### 2 Load / Store Instructions

| Instruction                | Description           |
|----------------------------|-----------------------|
| LDR Rd, [Rn,<br>#offset]   | Load word from memory |
| LDRB Rd, [Rn,<br>#offset]  | Load byte             |
| LDRH Rd, [Rn,<br>#offset]  | Load half-word        |
| LDRSB Rd, [Rn,<br>#offset] | Load signed byte      |
| LDRSH Rd, [Rn,<br>#offset] | Load signed half-word |
| STR Rd, [Rn,<br>#offset]   | Store word            |
| STRB Rd, [Rn,<br>#offset]  | Store byte            |
| STRH Rd, [Rn,<br>#offset]  | Store half-word       |

**Example:** LDR R0,  $[R1, #4] \rightarrow load 32-bit word from address R1+4$ 

#### 3 Branch / Control Flow

| Instruction | Description                      |
|-------------|----------------------------------|
| B label     | Unconditional branch             |
| BL label    | Branch with link (call function) |

BX Rm Branch to register (return from function)

BLX Rm Branch with link to register

BEQ label Branch if equal (Z=1)

BNE label Branch if not equal (Z=0)

BGT/BGE/BLT/BLE Conditional branches based on flags

/ . . .

#### 4 Stack / Subroutine

| Instruction     | Description                                   |
|-----------------|-----------------------------------------------|
| PUSH {Rn,,LR}   | Push registers to stack                       |
| POP<br>{Rn,,PC} | Pop registers from stack (PC = return)        |
| MSR             | Move value to special register (PSR, CONTROL) |
| MRS             | Move special register to general register     |

#### 5 Bit Manipulation / Misc

| Instruction         | Description            |
|---------------------|------------------------|
| LSL Rd, Rm,<br>#imm | Logical shift left     |
| LSR Rd, Rm,<br>#imm | Logical shift right    |
| ASR Rd, Rm,<br>#imm | Arithmetic shift right |
| ROR Rd, Rm,<br>#imm | Rotate right           |

TST Rn, Rm Test bits

CPSIE i Enable interrupts

CPSID i Disable interrupts

#### 6 Special Instructions for STM32 Peripherals

Memory-mapped I/O → use LDR/STR for peripheral registers

• Example: Toggle LED on PC13

```
LDR R0,=GPIOC_BASE

LDR R1,[R0,#GPIOC_ODR]

EOR R1,R1,#(1<<13)

STR R1,[R0,#GPIOC_ODR]
```

Cortex-M3 এ all peripheral interaction = memory-mapped, কোনো special I/O instruction নেই

#### Notes

- 1. STM32 Blue Pill = Cortex-M3 → **ARMv7-M Thumb / Thumb-2** only
- 2. All instructions are 16-bit or 32-bit Thumb
- 3. Arithmetic, logical, load/store, branch, stack, bit-manipulation supported
- 4. Peripheral access via **LDR/STR** on memory-mapped addresses